# Digital Design and Computer Architecture

### Lab 3: Thunderbird Turn Signal

#### Introduction

In this lab, you will design a finite state machine in SystemVerilog to control the taillights of a 1965 Ford Thunderbird<sup>1</sup>. *There* are three lights on each side that operate in sequence to indicate the direction of a turn. Figure 1 shows the tail lights and Figure 2 shows the flashing sequence for (a) left turns and (b) right turns.



Figure 1. Thunderbird Tail Lights



Figure 2. Flashing Sequence (shaded lights are illuminated)

<sup>&</sup>lt;sup>1</sup> This lab is derived from an example by John Wakerly from the 3<sup>rd</sup> Edition of Digital Design.

This lab is divided into four parts: design, SystemVerilog entry, simulation, and implementation. If you follow the steps of FSM design carefully and ask questions at the beginning if a part is confusing, you will save yourself a great deal of time. As always, don't forget to refer to the "What to Turn In" section at the end of this lab before you begin.

### 1) Design

Your FSM should have the following module declaration:

where xx are your initials. You may assume that clk runs at the desired speed (e.g. about 1 Hz).

On reset, the FSM should enter a state with all lights off. When you press **left**, you should see LA, then LA and LB, then LA, LB, and LC, then finally all lights off again. This pattern should occur even if you release **left** during the sequence. If **left** is still down when you return to the lights off state, the pattern should repeat. **right** is similar. It is up to you to decide what to do if the user makes **left** and **right** simultaneously true; make a choice to keep your design *easy*.

Sketch a state transition diagram. Define your state encodings. Hint: with a careful choice of encoding, your output and next state logic can be quite simple.

Choose a set of state encodings. At this point, you could write state transition and output tables and then a set of next state and output equations. Instead, we will design it in an HDL and let the synthesis tool choose the gate-level implementation.

## 2) SystemVerilog Entry

Create a new project named lab3\_xx, where xx are your initials. Choose the usual Cyclone IV EP4CE115F29C7 FPGA. In this lab, you'll use SystemVerilog rather than schematics. Instead of choosing ViewDraw, set the synthesis tool to <None> to use the built-in SystemVerilog compiler.

Create a new SystemVerilog HDL file and save it as lab3\_xx.sv. Enter Verilog code for your FSM.

### 3) Simulation

Create a testbench\_xx.sv file that convincingly demonstrates that the FSM performs all functions correctly. Simulate your FSM in ModelSim with your testbench.

You'll probably have errors in your SystemVerilog file or testbench at first. Get used to interpreting the messages from ModelSim and correct any mistakes. In fact, it's good if you have bugs in this lab because it's easier to learn debugging now than later when you are working with a larger system!

### 4) Hardware Implementation (This you will demonstrate in lab)

Download your design onto the DE2 board and test it in hardware.

Import the DE2 pin assignments as you did in previous labs.

You'll need to rename the inputs and outputs to connect them to switches and LEDs. This could be done with a global search and replace of signal names.

**Note**: the switches sometimes experience a phenomenon called *bounce*, in which the mechanical contacts bounce as the switch is opening or closing, creating multiple rapid rising and falling pulses rather than a single clock edge. If your lights seem to skip through multiple states at a time, it is probably because of switch bounce on the clock switch. With a bit of practice, you can learn to push the switch in a way that bounces less. It is also possible to build a circuit to "debounce" a switch, but that is beyond the scope of this lab.

#### What to Turn In

Please turn in each of the following items, clearly marked and in the following order as a single pdf file on Sakai. Remember that you will also submit the code in this lab report:

- 1. Please indicate how many hours you spent on this. This will help in calibrating the workload for next time the course is taught
- 2. Your FSM design, including a completed state transition diagram for your FSM. Scanned images are acceptable so long as they are easily readable.
- 3. Your lab3\_xx.sv code.
- 4. Your testbench xx.sv code.
- 5. Image of your simulation waveforms demonstrating that your FSM performs all tasks correctly. Please display your signals in the following order: clk, reset, left, right, lc, lb, la, ra, rb, rc.
- 6. How many registers and I/O pins does your design use? Does it match your expectations?
- 7. Briefly describe how you tested the system on the DE2 board and whether it worked according to the specifications. Did you observe switch bounce? (You may omit this in report).

You've now implemented your first design in SystemVerilog!

Note: Don't forget to use the cover page.